CA Test Variant 4

- 1. Consider a Linear Feedback Shift Register (*LFSR*) on 7 bits, constructed according to the following output sequence:  $q[0] \leftarrow q[6]$ ;  $q[1] \leftarrow q[0]$ ;  $q[2] \leftarrow q[1]$ ;  $q[3] \leftarrow q[2]$ ;  $q[4] \leftarrow q[3] \oplus q[6]$ ;  $q[5] \leftarrow q[4]$ ;  $q[6] \leftarrow q[5]$ .
  - a) Design, on a sheet of paper, the complete architecture of the 7-bit *LFSR* unit.
  - b) Implement, using Verilog language, an *LFSR* module, using instances of a D-type flip-flop unit.
  - c) Determine, by means of simulation, the output periodicity of the *LFSR* architecture.
- 2. Consider a combinational device having an input *i* and an output *o* on 4 bits, that encodes a 4-bit number in the *BCD-8421* format:

| Inputs                |       |       |       | Outputs |    |    |    |
|-----------------------|-------|-------|-------|---------|----|----|----|
| <i>I</i> <sub>3</sub> | $I_2$ | $I_1$ | $I_0$ | О3      | 02 | 01 | 00 |
| 1                     | 1     | 1     | 1     | 0       | 0  | 1  | 0  |
| 1                     | 1     | 0     | 1     | 1       | 0  | 0  | 0  |
| 0                     | 1     | 0     | 0     | 0       | 0  | 1  | 0  |
| 0                     | 0     | 1     | 0     | 1       | 0  | 0  | 1  |
| 0                     | 1     | 1     | 0     | 1       | 0  | 1  | 0  |
| 0                     | 1     | 1     | 1     | 1       | 1  | 0  | 1  |

Note: The unlisted inputs are expected to have an output decimal value of 11.

- a) Minimize the output functions on a sheet of paper using the Karnaugh maps method.
- b) Write a module that implements the resulting Boolean function after minimization. The module will be given a suggestive name (e.g. *BCD\_encoder*).
- c) Build a testbench for exhaustive evaluation of the *BCD\_encoder* module implemented in sub point b).

## Name:

- **3.** Construct a **16 x 36** Register File (**RF**) for assembling 36-bit data packets into a 576-bit block. The unit has a 36-bit input, **data**, a 4-bit selection line, **wr\_data**, a 1 -bit enable line, **wr\_en**, as well as **clock** and **reset** lines that are connected to each of the registers in the stack. For this:
  - a) Design, on a sheet of paper, a 4-to-16 lines decoder (dec\_4x16) architecture, and implement its module using Verilog language.
  - b) Design, on a sheet of paper, a 36-bit register (**rgst**) architecture, and implement its module using Verilog language.
  - c) Design, on a sheet of paper, the entire Register File by linking the above constructed designs together. Implement the **reg\_fl** module, using **a generate block.**
  - d) Implement, using Verilog language, a testbench for evaluating the functionality of the reg fl module

The architecture of a **16x32** Register File architecture is given below as support:



Score: 1. a) 1p; b) 1p; c) 1p | 2. a) 1p; b) 1p; c) 1p | 3. a) 0,75p; b) 0,75p; c) 75p; d) 0,75p | 1 bonus point | Total: 10p